juni 1992 OS-9 International 



Nr. 1 



startup 


1 


Europaisches Forum Fiir OS-9 


2 


EFFO Forum 20 


11 


OS-9 ftp-Archiv in der Schweiz 


14 


Offentlich zugangliche OS-9 Software 


16 


Ein OS-9 Gerate-Treiber 


18 


Erkennen von Exceptions 


25 


A Software Management System 


30 


In eigener Sache 


35 


Vorschau 


37 



Herausgeber: Redaktion: 

Marc Balmer Telefon +41 61 281 19 41 Marc Balmer 

Hagentalerstrasse 12 Telefax +41 61 281 19 53 Carsten Emde 

CH - 4055 Basel E-Mail os9-info@urz.unibas.ch 



startup 



Vor Ihnen liegt die orste Ausgahe von OS-9 International, dem Magazin fur OS-9 
Anwender und Software Kntwiekler. Von der Idee bis zur Realisierung dauerte 
es einige Zeit, doeh hoffe ieh, dass OS-9 International positiv aufgenommen wird 
und wir die fur dieses .Jahr geplanten Ausgaben herausgeben konnen. 

OS-9 International soil der Verbreitung von Infonnationen nind tun OS-9 dienen; 
es ist ausserdem Organ de.s KKKO, des Kuropaisehen Korums fur OS-9. 

Beim Durehhlattern wird Union aufFallen, dass OS-9 International mehrspraehig 
ist. Die Kntscheidung, ob ein Artikel libersetzt wird odor ob er in der Original- 
spraehe verofTentlieht werden soil, ist mir nieht leichi gefallen. Letztendlieh bin 
ich ab(T zur Kberzeugung gelangt, dass ein gut geschriebener Artikel in einer 
Kremdspraehe iinmer noeh besser ist als eine seldeehte Kbersetzung. 

Ieli stelle inuner wieder fest, dass die OS-9 (Jemeinde fiber ein grosses Potential 
vorfugt, das aber relativ sehlecht genutzt wird. Da die einzelnen OS-9 Anwen- 
der alio im "stillen Kammerlehf 1 sitzen und vor sieh bin programmieren, bleibt 
viol Know-how der Allgomeinhoit unzuganglieh. YVenn sieh jeder Programmierer 
zuorst seine Tools solber sehreibt, wird das Had unentwegt neu erfunden. Kin 
Krfahrungsaustauseh client deshalb alien OS-9 Anwendern. 

Ks gibt bereits einige regionale Benutzergruppen, die aber leider nieht viel Kon- 
takt untereinander pf logon. Diese Gruppen und Vereine sind aufgerufen, sieh zu 
nielden und sieh in OS-9 International vorzustellen. 

OS-9 hat noeh lange nieht die Beaehtung gefunden, diees verdient. Daran konnen 
wir alio etwas andern. (lanz besonders wiirde es mieh freuen, wenn fiir die naeh- 
sto Ausgabe von OS-9 International einige weitere Artikel von OS-9 Anwendern 
vorliegen warden. 

OS-9 International nioehte den wenigen Software- [lausern, die OS-9 Software 
entwiekeln, unentgeltlieh (Jelegenheit geben, ihre Produkte bekannt zu maehen. 
Aus diesem (Jruncl werden Sie pro Ausgabe maximal einen produktebezogenen 
Artikel finden. Bezahlte Werbung hingegen ist deutlieh gokennzeiehnet. 

OS-9 International ist nieht im Zeitsehriftenhandel erhaltlieh. Der Bezug erfolgt 
aussehliesslieh im Abonnement. Bitte sehen Sie dazu die Seite "In eigener Sa- 
(lie . 

Marc Bfilnwr 
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Werner Sickling 

OS-9 was ist das? Wer elie^se^ IVagc atif Anhieb boantworton kann, darf niit. 
dor weiteren Loktiire getrost aufhoren. Fiir all(\ <\'\c ex nicht so ganz genau wis- 
son, gostatten wir mis nur don loiehten Hinweis: OS-9 isl cm Be^triebssystem. 
Punkt. Also wirklich, ini (Jogensatz zu manchon anderom die das aiu'h von sicli 
bohaupten, ist en ganz be\stimmt eiii Betriebssystom. 

Viol intorossantor ist. sowieso, was OS-9 nicht ist. Ks ist z.B. donkbar ungoeignot, 
uni nial sehnell oiuon Brief zu sohreibon. Krstens gohl ox nicht sehnell und /wri- 
tens wird er nicht. schon ini Sinne^ (lev heutzutage vorlangten innereMi und ausse- 
ron Asthetik. dicsogar bci oinoni Schmierzettol mindostens Kotosatzreifo voraus- 
setzt. Ganz abgesehen von den Sehwicrigkeiton (lev dichterischen Sohopfung an 
sich - cine anstanelige Text vorarbeitung unter OS-9 orsehopft sicli auf dramati 
sche Wcisein metaphysisehor Niohtexistenz. I^J.^X , wcrden Sicsagen. 'ist das efwa 
nichtsT Na sicher eloch, T\?X ist absolut das Grosste. Jedenfalls wenn man d\e 
paar 10 Megabyte* auf dn* Platte* betraohtet. Piiel ohne Proviewer: wer zahlt die* 
Dauino, nennt die Namen, die* ihr Leben fur die G9-5 Probeausdruoko von Tanto 
Bertas Geburtstagsgruss lassen niussten? Also lassen wir elie^ Text .vorarbeitung 
ma] beiseito und wenelen mis otwas Krfroulioherem zu. 

Nehmen wir elie Tabellenkalkulation. Das bra.ueht nun wirklich jeder: sehnoll 
e*in paar Ausgabon zusammendividiereMi, eine Tabellc erstollen fiir don nachstem 
Quartalsbericht, die Auswirkung versehiedener Eingangsdaten feststelleu, das 
alios ist eine dor einfachsten Ubung(*n fur eine Tabellenkalkulation. Hurra, wie 
begeisternd, OS-9 ist nun wirklich das Betriebssystemi, mit dem man uni alio 
dioso Probleme einen mogliehst grossen Bogen inachen sollte. Kalkulieron ja, 
meinetwegen auch Tabellen, aber beides zusammen? 

Na ja, die Hauptelomane von OS-9 ist naturlich bei den Datenbanken zu suchen, 
das wissen wir alio. Was spricht schon gegen 'suchen 1 ? Suchon kann man immer, 
z.B. einen Record in der Datenbank. Ode*r ein Datenbankprogramm unter OS-9. 
Was haben die gemeinen Anwender ela nicht schon alios gesueht, und wenn sio 
nicht gestorben sind, ... 

CAD, klar, das hatte uns auch schon friiher einfalleu konnen, GAG, ("AM und 
CIM, da liegen die Starken von OS-9. Grafikdesign, Desktop-Publishing, alles 



OS-9, das etwas andere Betriebssystem 



das sind Einsatzgebiete, die unter OS-9 perfekt und mit minimalem Aufwand 
angegangen werden konnen. Nahezu gleich Null ist der Aufwand, und wen stort 
schon, dass das Ergebnis auch nur unwesentlich von derselben verschieden ist? 

Also vergessen wir OS-9. Wer braucht das schon. Benutzen wir einfach den 
vielgeschmahten Kompatiblen, der schafTt spielend die Bearbeitung von 20 par- 
allelen Echtzeitaufgaben, na gut, sagen wir 10, aber 5 sind es doch ganz sicher, 
wie bitte, 1.5 sagen Sie? Was funktioniert dabei nicht? Wieso kann man das 
nicht machen? Und wie gross durfen die Programme sein? Ehrlich? 



OS-9, das etwas andere Betriebssystem 

Voller Stolz erlauben wir uns anzupreisen: OS-9 kann alles, weiss alios, macht 
alles - vielleicht nicht immer so perfekt wie andere, dafiir aber manches, wovon 
andere nur traumen. Es gibt durehaus Textverarbeitung, Tabellenkalkulation, 
Datenbanken, wenn's denn unbedingt sein muss. Dafiir gibt es ein paar Extras, 
die man sonst vergeblich sucht: Eehtzeit verhalten, parallele Prozesse, minimale 
Systemanforderungen, modularen Aufbau, verschiebbare und von mehreren Be- 
nutzeni gleichzeitig verwendbare Programme, ROM-Fahigkeit, alle denkbaren 
und undenkbaren Programmiersprachen und was der wunderbaren Eigenschaf- 
ten mehr sind. 

Warum, so schreckt der besorgte Leser auf, hat sich dieses Wundersystem nicht 
langst auf breiter Front durchgesetzt? Wieso findet sich im einschlagigen Fach- 
zeitschriften-Blatterwald so gut wie nie auch nur ein Hinweis auf OS-9? Bitte 
kreuzen Sie den Vorschlag an, der Ihrer Meinung nach nicht die Ursache sein 
kann: 

□ Wenn alle diese Vorzilge von OS-9 ofFentlich bekannt wiirden, waren alle 
anderen Systeme schlagartig vom I^latz gefegt. 

□ OS-9 Plattformen sind viel zu tcuer und die Lizenzgehuhren sind viel zu 
hoch. 

□ Fine anstandige Auflagenhohe kommt nur zustande, wenn ein Betriebs- 
system moglichst viele Schwachen und Limitationen aufweist, iiber deren 
Fiehebung sich so herrliche Artikel schreiben lassen. 

□ OS-9 ist viel zu kompliziert, das kapiert der Leser nicht. 

□ Niemand kiimmert sich ernsthaft darum, OS-9 in grossem Stil bekanntzu- 
machen. 
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□ Das Software- Angebot ist viel zu mager. 

Womit wir jetzt ganz zwanglos die Uberleitung zu EFFO gefunden batten. Da 
es sicli bei OS-9 offensichtlieh uni das beste Betriebssystem der Welt handelt, 
miissen wir es der Welt nur noeh klar machen; aus vollig unbegreiflichen Griinden 
kommt sir nicht von alleine darauf. 



EFFO, was ist das? 



Die erste Bekanntschaft mil OS-9 endet normalerweise in einem Fiasko. I in 
Prospekt des Reehnorbauers best sicli alles so schon: Multiuser Multitasking- 
Realtime- Betriebssystem, und dann sitzt man plotzlich und unerwartet vor ei- 
nein Haufen Disketten und zwei dicken Ilandbuchern. Mil viol Glfick lauft der 
Hecliner auf Anhieb, aber welie, ein Treiber stirnint niclit ganz oder der De- 
scriptor muss an einer kleinen aber entseheidenden Stelle angepasst werden - 
wer von uns hat das niclit srhon erlel)t. Ohne jede Ahnung von dom neuen Be- 
triebssystem ist an dieter Stelle erst einmal Feieral)ond. Zugegeben, nach der 
20. Installation einer neuen Harddisk regt einen das niclit melir aub aber als 
Anfanger will der erste Superfrust erst einmal bewaltigt werden. 

Der zweite unerlaubte Tiefschlag ist gewissermassen scbon vorprogrammiert : 
wenn du 1 mitgelieferten (System-) Programme alio ausprobicrt sind, wird die 
Preisliste nach ein wenig Software durchstobert. Diese Suche ist, normalerweise 
nach drei bis funf Zeilen beendet , und der Sucher in der Wiiste hat das dumpie 
Gefiihl, jetzt endgiiltig im Hegen zu stehen: zuni einen slelit nichts Brauchbaros 
drin und ausserdem kostet das auch noeh ein Gold, ich meine richtiges Geld, 
nicht einfach nur Geld. Aha, denkt dor Kandidat, OS-9 ist etwas fiir Spezia- 
listen, die sicli alle Programme selber schreihem da gibt's halt nichts. In den 
Zeitschriften findet er sowieso nichts, und einen anderen OS-9 Anwender, den 
man fragen konnte, gibt es offenbar auch nicht. Das war's dann. 

Nun ja, ganz so schlimm ist es auch wieder nicht, aber der Haken ist das gewusst 
wo. Langst nicht alle haben Verbindung init einer Mailbox, die eventuell weiter- 
helfen kann. Die Wenigsten haben Zugriff auf das weltumspannende Usenet mil 
seinen ftp Servern und riesigen OS-9 Konferenzen, und wer ist sich schon voll 
bewusst, dass fast das gesamte Potential an Unix-Programmen mit geringcm 
Aufwand unter OS-9 lauft? Und wer sagt einem, dass diese gauze Pracht fast 
nichts kostet? 

Genau an dieser Stelle setzt EFFO, das Europaische Forum Fiir OS-9, ein. Wir 
bieten einen Rahmen zur Kontaktaufnahme mit Gleichgesinnten, wir stellen 



Die Teilnahme am Forum .. 



Losungen ffir immer wiederkehrende oder auch ganz spezielle Probleme vor, wir 
verbreiten Informationen fiber OS-9, die nicht ohne weiteres zuganglich sind, and 
wir sorgen fur die Verteilung vieler schoner Progranime. Dazu ist uns beinahe 
jedes Mittel recht, wie Sie sehen, verschonern wir jetzt sogar gefallte, plattge- 
walzte, vermantschte und getrocknete Baunie mit Druckerschwarze. Allerdings 
hat eine Zeitschrift immer etwas von einer Rinbalinstrasse; deshalb ist unser 
Hauptmedium die Diskette, die moglichst oft ihren Weg von Ihnen zu uns und 
wieder zurfick finden sollte. (Da niemand genau weiss, wieviele Baunie ffir die 
Herstellung einer Diskette ihr Leben lassen mfissen, haben wir hier ein vollig 
reines Gewissen.) 



Die Teilnahme am Forum ... 



Ca. 5 mal im Jahr organisieren wir einen Diskettenaustausch, bei dem alle 
Beitrage und Informationen von den Einsendern zusammengetragen und an die 
Teilnehmer zurfickgeschirkt werden. Dazu sendet jeder Interessierte zwei Dis- 
ketten mit eigenen Beitragen (oder zumindest formatiert) an den fiir das eigene 
("omputersystem zustandigen FFFO-Redakteur ein (Adressen sieheunten) - und 
damit ist auch schon alles Wichtige gesagt. Fine noch simplere Moglichkeit ist 
uns bisher nicht eingefallen. Altere Forumsausgaben sowie Disketten aus un- 
serer I > D-Sainmlung sind ebenfalls erhaltlich. Wie so etwas ungefahr aussieht, 
konnen Sie anhand des Inhaltsverzeichnisses von Forum 20 und aus unserer Li- 
ste mit PD-Disketten ersehen, die ebenfalls in dieser Ausgabe abgedruckt sind. 
Alle Beitrage konnen mittlerweile auch von einem ftp-Server in Basel abgerufen 
werden. 



... und was es kostet 



Dm gleich der allgemeinen Verwirrung Einhalt zu gebieten, die beim Betrachten 
der finanziellen Aspekte jedweden zu fibermannen droht, wollen wir hier einmal 
unsere Bochpreispolitik ausfiihrlich erlautern. Getreu unserer Devise der absolu- 
tv\\ Gewinnminimierung - was in letzter Konsequenz einen volkswirtschaftlichen 
Schwachsinn darstellt und eigentlich eine psychologische Unbedenklichkeitsbe- 
scheinigung erheischen sollte - kalkulieren wir ausserst knapp, aber brutal. 



Europaisches Forum Fur OS-9 



Was bekomme ich gratis? 

Nichts natiirlich. Jedenfalls nichis, was man anfassen kann. ABER, gesetzt den 
Kail, ich sende zwei formatierte Disketten em, vielleicht sogar mil eigenem CJc- 
dankengut, einem kleinen Briefchen, einem Ariikel oder einem Programmchen 
gefiillt, dann bekomme ich die Schlappscheiben sogar wieder. Und - das ist der 
Wahnsinnshammer - auf den Dingern ist auch noch mehr drauf als vorher. Der 
Bankkaufmann nennt so etwas 1 Wertschopfung\ der Wissenschaftler 'Perpetuum 
Mobile 1 , der Grime wahrscheinlich 'Ausbeutung unterprivilegierier Kmweltver- 
besserer 1 (bei den (Irunen ist eine Definition immer etwas langalmiger und muss 
unbedingt den BegrifF Hlmwelt 1 enthalten). Denn siehe, es steht geschrieben: 
l EKKO lasst dort Bytes wachsem wo vorher Wuste war und labt den Diirstenden 
aus nicht versiegendem BitstronT. Im Klartext: Die Teilnahme an der Korums- 
runde ist absolut gratis und unverbindlich. 



Was bekomme ich fiir 10 Schweizer Frankchli? 

Kine ganze Menge, vorausgesetzt, ich bin ein ordentliches EKKO-Mitglied. Fur 
diesen Dnmpingpreis liefern wir entweder eine alte Kornmsausgabe oder eine 
Public Domain Diskette*. Dabei handelt es sich immer nm logische Ausgaben, 
d.h. z.B. i.a. zwei physikalische Korumsdisketten oder eine physikalische PD- 
Scheibe. Kails das ganze Paket auch in komprimierter Korm nicht auf eine Kratz- 
platte passt, konnen es aber auch zwei oder drei lochzentrierte magnetpasten- 
beschichtete rundgestanzte schutzumhullte PVC-Klachprofile sein. Porto und 
Verpackung, sowie der Obulus fiir den Klapperteller selbst sind selbstverstand- 
lie h eingeschlosscn, ebenso natiirlich samtliche Mehr- oder weniger Wert- oder 
Warenumsatz-Steuern, die irgendwohin abzufiihren uns von vornherein in den 
Sinn zu kommen versagt blieb. 



Was bekomme ich fiir 20 Schweizer Frankchli? 

Einmal pro Jahr verschleudern wir dafiir das allergrosste nur denkbare Beate- 
Uhse-Sonderangebot, namlich eine Mitgliedschaft im EFTOClub. Damit verbun- 
den sind a-tens Sitz und Stimme in der Vollversammlung, beta das Recht, ein 
offentliches Amt bei EFFO zu bekleiden (tragt ein Amt eigentlich Hosen oder 
Rocke?) und drit-tens profitiert man von unseren zehnfrankigen Schleuderprei- 
sen. 



Was bekomme ich fur 60 Schweizer Frankchli? 



Alle diejenigen, die aus politischer, weltanschaulicher oder religioser Uberzeu- 
gung eine Mitgliedschaft ablehnen, erhalten fur 20 Franken jeweils eine alte 
Forumsausgabe oder eine PD-Diskette, logischerweise wieder logische Ausga- 
ben. Obwohl die Teilnahnie am Forum kostenlos und unverbindlich ist, freuen 
wir uns ueber jeden, der zusaetzlich Vereinsmitglied bei FFFO wird. Die Mit- 
gliederbeitraege werden verwendet, urn die im Zusammenhang mit dem Forum 
anfallenden Kosten zu decken. 

Voraussichtlich auf Forum 397 werden wir ein Programm verofFentlichen, das in 
jedem einzelnen Fall vorausbestimmen kann, ob sich eine Mitgliedschaft lohnt. 
Eine Arbeitsgruppe unserer Redakteure hatte bereits die erste Sitzung, und es 
steht audi schon die Sprache fiir das Programm fest: BASIC++. Es wurde ein 
Unterausschuss eingesetzt, urn den notwendigen Interpreter zu erstellen, wahr- 
scheinlich in COBOL. Mit an Sicherheit grenzender Wahrscheinlichkeit wird das 
fertige Programm einen PC AT SX mit VGA voraussetzen, der unter Windows 
27 einen Atari mit mgr emuliert. F.infacher gehts halt wirklich nicht. Und so 
etwas hat eben auch jeder, oder wenigstens zu haben, denkt sich zumindest die 
Industrie, die von sich behauptet, einen Standard zu vertreten. 

Mit einer gewissen Penetranz werde ich dabei immer an den Siegeszug des 
guten alten VVV Kafers erinnert. Das Gefahrt war hoffnungslos untermotori- 
siert, verfiigte iiber die Fahrleistung einer Schildkrote, hatte nicht den gering- 
sten (Kofferraum-) Speicher, den Bedienungskomfort eines Waschbretts und die 
Strassenlage einer Wassermelone. Aber das Ding hat sich durchgesetzt. Zugege- 
ben, den Witz habe ich auch nie begriffen. 



Was bekomme ich fiir 60 Schweizer Frankchli? 

Gesetzt den Fall, es rotten sich mehrere Gleichgesinnte zusammen und bilden 
eine nicht notwendigerweise terroristische Vereinigung, sondern z.B. eine Firma 
oder einen lockeren Haufen von Saufkumpanen, dann konnen sie eine Kollektiv- 
mitgliedschaft bei RFFO erwerben. Damit verbunden ist ein einzelner Sitz und 
Stimme in der Vollversammlung, und es nimmt auch nur ein Einsender an den 
Forumsrunden teil. Der Sinn ist wohl einigermassen klar: Arbeitsteilung. Ausser- 
dem soil der finanzielle Anreiz den Herdentrieb von ansonsten einzelkampferisch 
angehauchten OS-9-Frohnaturon fordern: eine gelegentliche direkte Kontaktauf- 
nahme mit Gleichdenkenden zum Zwecke des Informations- und Gedankenaus- 
tauschs kann durchaus befruchtend wirken. Das geliebte Eheweib ist haufig auch 
ganz froh, wenn der Gottergatte ab und zu das Feld raumt. Und gibt es etwa 
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eine schlagkraftigere Methode, den Haushaltsvorstand von eventuell aufkeimen- 
den Begleitbestrebungen abzuschrecken, als ein ComputerklobbY 



Wer bekomrat wieviel Rabat t? 



Vergleioht man einmal unsere doch ziemlirh iiberhohten Preisc mit den gangigen 
Klobbbeitragen, die den arrnen fohlgc*loite*t<*n Besitzer <>ines Industrie-Standards 
in seiner natiirlichen Verzweiflung voll erwischem dann sieht das Verbal in is sehr 
ungiinstig aus. (Im tiefsten Inneren unseres Herzens wissen wir selbstverstand- 
lich, dass unser missionarischer Einsatz bei den Kompatiblen und solcben. die es 
sein wolleru urn (irossenordnungen wichtiger ware, als bei OS-9, aber wir schaffen 
es nicht, genugend Mitleid zu empfinden, wir schaffen es einfach nicht.) Jeden- 
falls sahen wir mis deshalb genotigt, eine ziemlirh ansgesehlalene Rabatt stalfel 
einzufiihren. 

1. Schiller, Studenten, Rent run* unci Invalide erhalten einen generellen Nach- 
lass von 0%. Das beriicksichtigt unter anderem auch die Tatsache, dass die 
genannte Personengnippe hentzutage fiber Haushaltsmittel verfugt, die einem 
gestandenen Familienvater das schiere Salzwasser in die Augen treibt. 

2. Alle, die einen eigenen Beitrag in irgend einer Form zum Forum einsenden, 
erhalten cincn Rabatt von 100% auf die laufende Forumsrunde und von 0% auf 
altere Ausgaben und PD-Disketten. Dahinter steht die Idee, dass das Forum nur 
mit Hilfe von eingesandten Beitragen funktioniert. Wenn wenig hereinkommt, 
dauert eine R uncle 1 eben langer; wenn nichts hereinkommt, isi die Idee gestorben 
und wir ersparen uns ziemlich viel Arbeit. Wenn sich aber moglichst viele an den 
Gedanken gewohnen, dass ein eigener Beitrag alien anderen und letzlich auch 
ihm selbst nfitzen kann, dann seben wir rosigen Zeiten entgegen. 

3. Diejenigen, die nicht unter die vorhergehenden Cruppen fallen, erhalten einen 
panschalen Rabatt von 0%. Damit mochten wir unserer Freude Ausdruck verlei- 
hen, dass Sie EFFO mit Wohlwollen gegeniiber stehen und unsere Ziele tatkraftig 
unterstiitzcn. 

4. Die Rabattstaffel fiir ausgewahlte Teile, sagen wir mal Forum 7, Disk 2, Tracks 
13 bis 27, oder auch ein Mengenrabatt sind in ihrer Konzeption und in den 
Ausfuhrungsbestimmungen noch komplizierter. Also fragen Sie besser gar nicht 
erst nach. 

5. Einen Trick wollen wir aber noch verraten: wenn Sie Ihren Redakteur ganz 
lieb bitten, ob er nicht vielleicht einfach noch mal so schnell diese oder jene 
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Diskette beilegen konnte, dann wird er es moglicherwcise sogar tun. Redakteure 
sind auch nur Menschen, mid bekanntlich ist das Fleisch willig, abrr dor Geist 
... ich sage nur: der Geist - wenn ich inir vorstelle, wie dor ist ... 

Sie konnen leicht ausrechnen, dass der FFFO-Jahresbeitrag ungefahr dazu aus- 
reicht, das Riickporto fur ca. (i Forumsrunden zu bezahlen. Also heisst es uberall 
zu sparen, denn wenn F] FIX) erst eimnal pleite ist, dann ist KFFO pleite und 
dann gute Nacht, Marie. Allerdings sind wir durehaus bereit, bei grosseren Pro- 
jekten einen finanziellen Heitrag zu loiston . Wenn z.B. jemand eine vollstandige 
T[<]X Implementation auf 50 Disketten beistruern mochte, dann werden wir sieher 
eine befriedigende Losung fur alle Betedigten HiuUmi. 

Das ist also in aller Kiirze uiiscro Prcisliste. Klar, ubersichtlich und von ge- 
radezu dramatiseher Schlicht heit . Fbrigens: alle ordentlichen FFFO-Mitglieder 
haben natiirlich das Recht, an der nachsten Generalversammlung miindlieh oder 
schriftlich ihre eigenen Vorstellungen darzulegen. 



Ressortleiter des EFFO 

Hier sind die verantwortliclien Ansprechpart ner fiir alle moglichen Arten von 
Problemen. Wir beantworten fast jede Frage, oder kennen zumindest jemandeiu 
der jomanden kennt, der jemanden kemit, 

ATARI, Macintosh 

Philip Maechler, Grundwiesstrasse 15, CH-8700 Kiissnacht/ZH 

+41 1 910 41 85 

cH68k 

Guido Hollenstein, Obere Weidstrasse 8, CH-6343 Rotkreuz 

C:+41 42 44 74 06, P:+41 42 64 25 59 

GFPARD 

Reto Peter, Wallisellcnstrasse 483, CH-8050 Zurich 

G:+41 1 236 66 75, P:+41 1 322 74 52 

VMF, GMX micro 20 

Lukas Zeller, Postfach 1, CH-8024 Zurich 

G:+41 56 83 33 77, P:+41 1 26F35\89 

mc68000 

Thomas G. Schiele, Winterthurerstrasse 297, CH-8057 Zurich 

G:+41 1 236 47 61, P:+41 1 311 22 35 
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NDR- Klein Computer 

Heinz Pauli, Gerbiweg 15, CH-8910 Affoltern a.A. 

+41 1 761 10 22 

PD Organisator 

Stephan Paschedag, Bauernhalde 5, CH-8708 Mannedorf 

G:+41 56 83 33 77, P:+41 1 920 32 77 

Redaktionsleitung 

Werner Stehling, Seilervvis 3, CII-8606 Greifensee 

G:+41 1 256 42 21, P:+41 I 940 05 00 

Mitgliederverwa.lt ung 

EFFO, Postfach, CH 8606 Greifensee 

Kontaktadresse Deutschland 

Computer Verein ((We), Otto F. Tutzauer, Willihrachtstrasse 13, 

D-W-6000 Frankfurt/M 50, +49 69 52 84 95 

Postsrheckkonto: KFFO 80-48'254-| Zurich, Srhweiz 



Werner Stehling ist Physikcr. Er btschdftigt sich beruflich an der E/FH Zurich 
wit technischen Entwicklungt n im Hereich der Iladioastronomie . Werner Steh- 
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WICHTIC FFFR ALLF FORUMS TFILNFHMFR: 
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alle Software, die von FFFO vorwaltet wird, 
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und wenn moglich, Informationen /u zukiinftigen 

Forumsbeit ragen in diescm Format liefern! Virion Dank! 
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Wer ist wer bei FFFO und ini Forum 
Inhaltsverzeichnis friiherer Forumsdisketten 
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brief . * 



Briofo dor aktivon Toilnohmer am Forum 



SOFTWARE/SPOOLER 

pr^queue . c 
pr.spooler . c 

print . c 

printer .h 



Task, die in die Queue schrcibt. Von print gostartod. 

Task, die von dor Queue Host und auf don Drucker 

schrcibt. 

Programm zum Ausdnickon mittols dor Queue. 

Dor Druckvorgang ist Event gestouort. 

Definition dor Kontroll-C 'odes. Fiir Epson, NEC, Star. 



SOFTWARE/PIP E 

wise-crack* 

_note_pipe 

ask* 



wise_(Tack f i i lit eine bozoichnelo Pipe mit sohr 
intelligenten Logos, ask holt die ersto Zoilo diosei 
Pipe. 



S0FTWARE/0S9LIB 

MAN/*.prf 
DEFS/*.h 



Manual Seiten dor OS91ib in proff Format 
Header Datoion dor OS91ib 
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SOFTWARE/PRQCCOMM 

AttFils* Inter-Prozess-Kommunication mit Beispielen, Brief 

HARDWARE/CT68000/GI0JTRAPHANDLER 

files. ausdrucken Anleitung zum Ausdrucken der Textdateien. 

giocharset.a Zeichensatze fur Block, Futur, Latein und Prestige. 

Diese Satze werden auch von der Emulation von Forum 19 

verwendet. 
giodemo.a Demo Programm, welches den Trap Handler verwendet. 

giographic.a GIO Traphandler 

giographic . * Definitionen 

giographic.txt Beschreibung des GIO Trap Handler 

giolib.a C Interface 

giolib.h Beschreibung der C vSchnittstelle 

giotest.c Testprogramm der C Schnittstelle 

makefile Makefile des GIO Trap Handler 

HARDWARE/GEPARD/FATJONT 

f at_^ontset Ein fetter Zeichensatz fiir Vortrage 

conv2eff o Ersetzt Umlaute durch Doppelbuchstaben 

ptop, ptob Fiir das Erzeugen und Zusammenstellen von Textdateien 

HARDWARE/GEPARD/DRIVER 

* Druckertreiber fiir Epson LQ 850 und Fat_Font 

HINWEIS: Allc "*.hlp", "*.hlib" und "*.ndx" Files sind Help-Files fuer 
das neue hierarchische HELP-Utility (siehe PROGRAMME/C/HELP auf ForumJO). 
Sie sollten unverandert ins Directory /dd/SYS/HELP kopiert werden. Auch Manu- 
al- Pages "* .man" sowie die alten (original-Microware) Helpfiles (ohne Extension) 
gehoren dorthin, damit HELP sie finden kann. 



OS-9 ftp- Arehiv in der Schweiz 



(lute und preiswerte OS-9 Software konnte bisher praktisch nur auf Diskette 
bezogen werden. KFFO und audi TOP in Mnnchen stellen auf Disketton Soft- 
ware von hoher Qualitat gegen eine geringe oder gar koine Bearboitungsgebiihr 
zur Verfugung. 

Fiir vide OS-9 Anwender ist jedoeh ein Online Zugriff auf OS-9 Software an- 
genehmer. Vor einiger Zeit hat denn audi ein amerikaniseher Sysop auf eineni 
Rechner am Internet ein Software- Arehiv eingeriehtet, das OS-9 Software welt- 
weit zur Verfugung stellt 1 . Da der Rediner in den USA stoht, ist der Filetrausfer 
nadi Furopa sehr tenor. Audi wenn die moisten Benutzer die Filetransfers nidit 
selber bezahlen ntiissen, entstehen fiir den Systembetreiber hohe Kosten. 

I bn OS-9 Software fiber Netzwerk audi in Kuropa zu geringeren Kosten vor- 
iiigbar zu inadien, wunle am Institut fiir Informatik dor University Basel ein 
OS-9 Software Arrhiv eingerichtet, das offentlich fiber ftp (file transfer protocol) 
zuganglieh ist. 

Das Arehiv in Basel gleicht vom Aufbau und Inha.lt her deni bereits genamiteu 
Arrhiv in Wisconsin. 

Urn das OS-9 Arehiv benutzen zu koniien, mussen Sie Zugang zum Internet ha- 
ben. Wenn Sie einen Account auf einem Uni-Rodinor habon, steht Ihnen ftp im 
Allgemeinen zur Verfugung; fragen Sie im Zweifelsfall Ihren Sysop. 

Das OS-9 Arehiv ist unter dem symbolisdien Namen lucfj.tji. unibas. eh odor der 
nuinerisehen Adresse 131.152.81.1 erreichbar. Wie bei vielen ftp-Servern iiblicli, 
ist der Benutzername anonymous, die eigene Mail- Adresse client als Passwort: 



$ ftp lucy.ifLunibas.ch . . . 

Name (lucy. if i .unibas . ch: muster) : anonymous 

Password: muster@urz. unibas. ch 

FTP> cd osk 

FTP> help 



^ermit.cs. wisc.edu, IP Adresse 128.105.8.24 
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Das Passwort wird nicht angezeigt, im obigen Beispiel client es nur zur Verdeut- 
lichung. 

Sie findon auf dem Server die Datei ls-lR, die den aktuellen Inhalt des Archivs 
enthalt. Bitte durchsuchen Sie das Archiv nicht "von Hand", die Datei wird 
laufend aktualisiert. 

Fur Uploads steht Iimen das Verzeichnis incoming zur Verfiigung. Dateien, die 
Sie 1 in incoming ablegen, werden vom Sysop gesichtet und dann an den richti- 
gen Ort kopiert. Urn diese Arbeit zu erleichtern, sollte zu jeder Datei ein kurzer 
Konunentar per E-Mail an os9-info@urz.unibas.ch geschickt werden. 



Offentlich zugangliche OS-9 Software 



Damit Sie eine OS-9 "Quelle" in Hirer Nahe finden konnen, unterhalt OS-9 In- 
ternational eine Liste von offentlich zuganglichen Ooniputersystcmeih die OS-9 
Software anbieten. 

Die Liste gliedert sich in zwei Teile, Systeme mil Anonymous FTP Zugang unci 
Systeme niit Modem-Zugang (Mailboxen, BBS). 

Die Liste ist nicht vollstandig. Wir bitten Sie daher, mis alle Ilinen bekann- 
ten Mailboxen oder F TP-Archive mitzuteilen, die OS-9 Soft wan* anbieten. Sie 
erreichen uns am schnellsten via lvMa.il an os9-info@urz.unibas.ch. 



Anonymous FTP 



Land 



FTP Adresse 



Dcutschland reseq.regent.e-technik.tu-muenchen.de 
tupar-a.iTiani.infonnatik.rwth-aachen.de 
ifi.informatik.uni-stuttgart.de 
athene.uni-paderborn.de 
sunO.urz.uni-heidelberg.de 



Finnland 


nic.funet.fi 

mcsun.eu.net 

uunet.uu.net 


Australian 


brolga.cc.uq.oz.au 

kirk.bu.oz.au 


Japan 


srawgw.sra.co.jp 
toklab.ics.osaka-u.ac.jp 

oskgateO.mei.co.jp 


Frankreich 


irisa.irisa.fr 


Schweden 


sunic.sunet.se 


Schweiz 


lucy.ifi.unibas.ch 



USA 



hermit.cs.wisc.edu 
wuarchive.wustl.edu 



Mailboxen und BBS 



Mailboxen und BBS 

Land Mailbox Modem-Nuinmer Bps. 



.SWjuv/'r (Jepard's Oracle 01:50:5 70 57 0600 

VVOPH 001 281 55 52 1 1100 

( I'sorname: os9) 

kito bbs 

( fiber Kometli erreichbar) 
ISA The IVnetralor BBS York (71 7) 7 1 1 507S 2100 

( 'olor ( Jalaxy Milky Way (115) <SS:{ 0090 2 100 

(OS-9/0S09 Network, 12 Nodes) 

ACS, Inc. BBS (101) 050 2091 ??? 

(KII)O 1:5:5/510) 



Ein OS-9 Gerate-Treiber 



A/arc fiiihncr 

Das Betriebssystem OS-9 orfreut sieh dank seiner Modularitat in dor Industrie 
voi' alleni als Steuerbetriebssystem grosser Beliebtheit. 

lnsbesondere die Moglichkoit, nene Hardware 1 durch Treiber ins Bet riebssystonr 
zu integrieren, tragi in holiem Masse zur Klexibiltat und Beliebt heit von OS-9 
bob 

Die Treiberprogrammierung. obwohl tlieoretisdi nicht sonderlieli sehwierig, bie 
tot in dor Praxis dorli moist oblige Sdiwierigkeiten. Dalier werden denn audi 
oft Periphoriebaustoine direkt adressiert, statt oinen OS-9 koniormen I VcmIxm- zu 
srlireiben. 

l)er grundsatzlielie Auibau ernes OS-9 lreibers soil im lolgonden besehriebon 
worden. Der hior vorgestellte IK^iIxm erl'ullt allerdings keino besondors wicbtige 
l'Unkl ion, diont er dodi lodiglieh dazu. die St at usanzoigo (oin Digit Ilex-Display) 
eines V M Kbus ( 'omputers (K"). I , L I IX 1 . Mainz. Deutsrhlaiid) anzusteueru. 



OS-9 kennt verschiedene Treiber-Arten 



Xiebt alio Peripheriegerate lassen sich in gleieher Woiso ansprediom Hin Bild- 
seliirm Terminal emplangt zum Beispiel rin Zeieben nadi dom anderen fiber 
eine s<M'i<dl<^ Leitung. Hs ist also ein ttr /eirhendTir Zeidieif -( lerat oder uin OS-9 
Tenninologie zu verwendeio oin Sequential Character File Deviee kurz SOF 
Device. 

Fest plat ten-Troiber translerieren ganw 1 Datenblooke nnd konnen audi noeh ge- 
zielt Ini'ormal ionen auf die Pestplatte schreiben oder von ihr lesen. Fs handelt 
sich hior also inn wahliYeien BlockzugrHF. Kin solrhes (lerat nennt man Handoni 
Block File Deviee ( RBF-Deviee). 



~(ierate- Treiber werden von Microware, Inc., dem llerst.eller von OS-9. als Toil des Be 
triebssy stems angesehon 



Der Aufbau eines OS-9 Treibers 



F'dr-Managev 


(leriitf'klasse 


SCK 


Terminals, Oruckrr 


liHV 


FestplaUen, Disketten 


SBF 


Magnet-Tapes 


NFM 


OS-9 Netzwerk 


pipeman 


Pipes 



Abbildung I: OS-9 Pile-Manager 

Magnet bander miissen nochmals anders angesteuert werden. llier werden zwar 
audi gauze Dafenblocke fiber! ragem aber es gibi keinen wahlfreien ("Random") 
Zugriff mehr, sondern die Dalenblocke werden sequentiell auf das Hand geschrie- 
ben. Diese Art des Xugriffs isi. aus OS-9 Sidit eine weitere Klasse fiir sidi, man 
nennt solche (Jerate Sequent ial Hlock File Devices (SB1 Dev ire). 

Die Fnterscheidung in verschiedene Oerate oder Fileklassen (indet aber iiicht auf 
der Stufe des Device Treibers statt . sondern auf d(M' Stufe des File-Managers. Kin 
Pile-Manager kennt die Desonderheit en der jeweiligen (lerafeklasse und ninunt 
die Ansteuerung via Treiber enfsprochend vor. 

Jede Klasse von (!oraton oder Devices hat ihren eigonen File-Manager. So gil)t 
es einen S(T -. (Mncii UIJF- und einen SHF-Filemanagor, die zum Standardum- 
iang jedes OS-9 Systemes gohoren. Weitere. nicht standardmassigo Filemanager 
konnen zum Beispiel MS-DOS Disketten unter OS-9 verwalten. 

Kin weiteret\ vvic htigor Filemanager isi der Pipe-Manager. Fine Pipe ist, im Prin- 
zipein FIFO-Speichei\ den Programme zum Beispiel zur Koinmunikation benut- 
zen konnen. OS-9 kennt "named" und "unnamed" Pipes, "named' 1 Pipes konnen 
Sie fiber das Device /pipe ansprechen. 

Abbildung I zeigf Ihnen die wichtigsten OS-9 Filemanager in einer Tabelle. 



Der Aufbau eines OS-9 Treibers 



Die Untorscheidung von Oerateklassen gesdiieht, wie schon erwahnt, nicht auf 
Treiberehene; der Treiber muss sich also nur um die eflfektive Ansteuerung eines 
(Jerat.es kummern. 
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Routine 


Funktion 


I NIT 


Initialisation des Treibers 


READ 


Lesen von Daten 


WRITE 


Schreiben von Daten 


PFTSTAT 


Setzen des Treiber-Status 


OETSTAT 


Ermitteln des Treiber-Status 


IRQSERV 


Interrupt Service Routine 


EXCSERV 


(noch nicht unterstiitzt) 



Abbildung 2: Unterprogramme eines OS-9 Treibers 

Ein OS-9 Treiber hat immer denselben Aufbau. Er besteht aus sechs uiitersltitz- 
ten unci einem reservierten Unterprogramm niit definierten Aufgaben. Abbil- 
dung 2 zeigt in Tabellenform die sieben Unterprogramme und Ihre Aufgaben. 



Der STATDISP-Treiber 

Ini folgenden Ahschnitt wird der OS-9 Treiber fur das Statusdisplay des ge- 
nannten VMEbus-( Computers besehrieben. Das Statusdispla.v ist an der Adresse 
$FEC0-1000 Hex anzusprechem wobei das obere Nibble* des Bytes den anzuzei- 
genden Wert enthalteu muss. Der liter vorgestellte Treiber erwartet allerdings 
entweder einen Wert von $00 bis $0F oder den ASCII Code des anzuzeigenden 
Zeiehens ('0 1 4 9\ C A' 'F'). Fur die ordnungsgemasse Funktion des Treibers 
ist natiirlich ein Deskriptor erforderlieh, der unter anderein audi die Hardware 
Adresse des Displays enthalt. 

Das Statusdisplay lasst sich hardwarebedingt nicht auslesen, weslialb der Treiber 
den aktuellen Wert im statischen Speicherbereich ablegt und ihn bei Bedarf als 
Wert zuriickliefert. Es ist aber moglich, dass andere Software, die nicht diesen 
Treiber verwendet, in der Zwischenzeit das Statusdisplay verandert hat. Der mil. 
READ erhaltene Wert muss also nicht unbedingt stimmen. 



Modulheader 



* OS-9 Device driver for the EUR0C0M-5 Status Display 

* OS-9 Module header: 
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nam 


statdisp 




ttl 


Eurocom-5 status display driver 


Edition 


equ 





Typ.Lang 


set 


(Drivr<<8)+0bjct 


Attr.Rev 


set 


((ReEnt+SupStat)<<8)+0 


Stacksize 


equ 






psect statdisp ,Typ_Lang, Attr _Rev, Edit ion, 0, St atEnt 
use defsfile 



Statischer Speicherbedarf 

* Static storage offsets 

vsect 
DispVal ds.b 1 Current display value 
ends 



Treiber Einsprung Vektoren 

* Entry vector table 
StatEnt 



dew 


Init 


dc .w 


Read 


dew 


Write 


dew 


GetStat 


dc .w 


PutStat 


dew 


Term 


dew 


(No exception handler) 



INIT- Routine 

* Initialize status display 



* 



Init: movea.l V_P0RT(a2) ,a0 get port address 
move.b #0,(a0) write '0' 
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move.b #0,DispVal(a2) 

clr.w dl 

rts 



store it for READ 
no error 
return 



READ-Routine 

* Read: Return the value stored by WRITE or INIT 
* 

Read: move.b DispVal(a2) ,d0 get value 
clr.w dl no error 

rts return 



WRITE-Routine 



* Write: Display value and store it in DispVal(a2) 
* 



Write: movea.l V_P0RT(a2) ,a0 

move.b dO,dl 

cmpi.b #$Of,dO 

ble.s Display 



get port addres 
save character 
check if value <= 16 
yes, display 



cmpi.b #'0',d0 

blt.s WriteEx 

cmpi.b #'9', dO 

ble.s WriteAsc 



value < '0'? 
yes, exit 
value <= '9'? 
write ASCII char 



bclr #5,d0 

cmpi.b #'A',dO 

blt.s WriteEx 

cmpi.b #>F\dO 

bgt.s WriteEx 

subq.b #7,d0 

bclr #5,dl 



force uppercase 

value < J A'? 

yes, exit 

value > 'F'? 

yes, exit 

subtract 7 

force uppercase in char 



WriteAsc: subi.b #'0' ,d0 

Display: move.b dl ,DispVal(a2) 
lsl.b #4,d0 



make J 0> -> #0 

store character 

shift into upper nibble 



Der STATDISP-Treiber 
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WriteEx: 



move.b dO,(aO) 

clr.w dl 
rts 



display it 
clear carry 



GETSTAT-Routine 



* GetStat 
* 


: Get 


device status 


GetStat : 


cmpi . w 


#SS_Ready,dO 




bne . s 


GetStalO 




clr.w 


R$dl(a5) 




move.w 


#$01,R$dl+2(a5) 




rts 




* return 


eof status 




* 







ready status? 

no 

sweep hi word of register 

return input char count 

(carry clear) 



GetStalO: cmpi.w #SS_EOF,dO 
beq.s GetSta99 



End of file? 

yes, return (carry clear) 



* return error for unknow service requests 
* 



Unknown: move.w #E$UnkSvc,dl 
ori.b #Carry,ccr 

* return to caller 
* 

GetSta99: rts 

PUTSTAT-Routine 

* PutStat: Set device status 
* 



Unknown service code 
return carry set 



PutStat: cmpi.w #SS_0pen,d0 



new path opened? 
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beq.s PutSta_90 

cmpi . w #SS_Close ,dO 
bne . s Unknown 



path closed? 



PutSta_90: moveq.l #0,dl 
rts 



clear carry 



TERM-Routine 



* Term: Terminate status display 
* 



Term: 



movea.l V_P0RT(a2) ,a0 

move.b #0,(a0) 

move . b #0 , DispVal (a2) 

clr.w dl 

rts 



get port address 
display '0* 
store it 
no error 
return 



Marc Balnier bcschdftigt sich schon scit Idngcrer Zcit bcrujlich mil OS-9. St it 
inch r als zwei J alum spit It tr in it dt in Clcdankt n, cine Zt itsclirift ht rauszubrin- 
gen, die ganz OS-9 gewidtnet ist. Wenn Sic ilnn inittt Hen moehten, ob dies cine 
gate Idee war odcr nicht, konn.cn Sit ihn privat unit r dt r 7W. Nr. +/ f I 61 / r J 
OS S5 enrich en. 



Erkennen von Exceptions 



(larsten Etude, Wolfgang Ockcr 

In der Prozessor- Eami lie MC680xO von Motorola ist eiii sehr machtiges Instru- 
ment zur Echlerbearbeitung implementiert: das Exception Processing System. 
Dabei unterscheidet man im Prinzip zwei verschiedene Arten von Exceptions, 
interne nnd externe. Interne Exceptions entstehen bei der Bearbeitnng bestimm- 
ter Instruktioncn, z.B. Teilung (lurch Null oder Anga.be einer nicht vorhandenen 
Instruktion; externe Exceptions konnen durch Hardware-spezifische Interaktion 
ausgelost werden wie z.B. das Adressieren nicht vorhandener Bus-Adressen oder 
durch Interrupt von I/O-Bauelementen. In jedem Eall von Exceptions reagiert 
der Prozessor in vergleichbarer Weise auf das Ereignis. Zunachst werden be- 
stimmte Infonnationen zum Zeitpunkt des Auftretens der Exception auf dem 
System-Stack abgespeichert. Dabei kann es sich im einfachsten Eall mir urn den 
aktuellen Stand des Status-Registers und des Programm-Zahlers (sogenannter 
short stack frame) handeln, in anderen Eallen. z.B. Bus Error beim M( -68030, 
werden bis zu 90 Byte an diagnostischer Information auf dem Stack gespeichert. 
In einem zweiten Schritt verzvveigt der Prozessor dann an eine Adivsst 1 , die aus 
der sogenannten Vector Base Address und der Art der Exception berechnet vvird. 
Diese Vector Base Address ist, bei den Prozessoren MC68000 und MO68008 im- 
nier 0, beim MC68010 und (lessen Nachfolgetypcn besteht ein eigenes Register 
(das vbr Register), das mit der movec-Instruktion angesprochen werden kann. 
Tabelle 1 zeigt einen Auszug der Exception-Tabelle. 

Am Ende des Exception-Unterprogramms steht nonnalerweise ein Return-Be- 
tehl, nach dem der Prozessor an die Instruktion zuriickverzweigt, an der die 

Vektor Nummcr vbr-Offset Ikdeutiuig 






000 


Reset: Interrupt stack pointer 


1 


004 


Reset: Programm-Zahler 


2 


008 


Bus-Fehler 


3 


OOC 


Adress-Fehler 


4 


010 
usw. 


IUegale Instruktion 



Abbildung 3: Begin n der Exception- Vektor- Tabelle 
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Exception aufgetreten ist. In der Regel erfolgt die Weiterbearbeitung des Pro- 
gramms unmittelbar im Anschluss an die fehlerbeliaftete Instruktion, bei Bus- 
oder Adress-Fehlern wird die fehlerhafte Instruktion erneut ausgefulirt (retry). 



Exception-Unterprogramme im User-Mode 

Das Definieren eigener Exception-Unterprogramme im User-Mode isl unter OS-9 
rocht einfach, da hierfur der spezielle System- Aufruf E$Trap existiert. Soil zuin 
Beispiel das Auftreten oiner Teilung durrh von einem Benutzer-Programm 
abgefangen werden, so braucht man nur eilie mit -1 abgescldossene Tabelle, 
welehe die gewiinschte Trap-Nuniiner und die Adresse des neuen Except ion- 
Unterprogramms enthalt, anzulegen und die Adresse* dieser Ta belle im Regi- 
ster al dem Systeni-Aufriif E$Trap zu iibergeben. Im folgenden Programm- 
Aussehnitt ist ein kurzes Beispiel fur diese Vorgehensweise gegeben: 

psect _zerdiv_a, 0,0, 0,0,0 

_zerdiv: move.l #0,a0 use current stack in case 

of exception 
lea.l ExcpTbl(pc) ,al load new exception table 
os9 F$STrap define it 

rts 
ExcpTbl dew T_ZerDiv,ZerDiv-*-4 

dew -1 End of Table 

ZerDiv . . . here comes the new exception 

handler 



Exception-Unterprogramme im System-Mode 

Leider besteht die genannte Moglichkeit im System-Mode, z.B. in einem Gerate- 
Treiber, in dieser Weise nicht. Es ist moglich, dass Microware zu einem spateren 
Zeitpunkt fur diese Aufgabe eine Funktion bereitstellt; einen vermutlich fur die- 
sen Zweck vorgesehenen siebten Fiusprungpunkt gibt es ja bereits jetzt in jedem 
Treiber. Zur Zeit muss man das Ersetzen des Exceptions- Unterprogranims aber 
noch "von Hand" vornehmen. Da diese Technik zwar relativ einfaeh, aber nur 
sparlich dokumentiert ist, folgt hier eine entsprechende Beschreibung. Beson- 
deres Schwergewicht wird dabei auf die Erkennung eines Bus-Fehlers gelegt. Als 
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Beispiel soil ein Treiber fur eine verschiedenartig konfigurierbare Hardware an- 
genommen werden, bei der vorgegebene Adressen unter bestimmten Umstanden 
physikalisch entweder vorhanden sind oder nicht. 



Praktische Realisierung 



Dor "geschutzte Zugriff" auf eine fraglich existierende Hardware- Adresse auf 
Treiber-Ebene lauft in mehreren Schritten ab: 

• Erkennung des Prozessor-Typs, entspreehendes Berechnen und Speichern 
der Adresse des Standard-Bus-Fehler Exception-Programms 

• Sporren aller Interrupts 

• Einsetzen des eigenen Exception-Unterprogrannns 

• Durchfuhren der kritischen Operation 

• Ruckinstallieren des Standard Exception-Programms 

• Freigabe der Interrupts 

• Abfragen eines Fehler-Flags, ob ein Bus-Fehler aufgetreten ist und ent- 
sprechende Vearbeitung des Problems 

An einer anderen Stelle des Program ms muss sich das eigene Exception-Unter- 
programm befinden, in deni das genannte Flag im Fehlerfall gesetzt wird. Eine 
besondere Problematik ergibt sich nun im Zusammenhang mit dem Riicksprung 
aus dem Exception- Unterprogramm in die normale Weiterbearbeitung. Norma- 
lerweise, d.h mit Ausnahme von Bus-Fehler und Adress-Fehler, wird die aktu- 
v\\c Instruktion zu Ende gefiihrt und ein einheitliohes Stack frame angelegt. In 
diesen I^allen kann man, wie im oben genannten Beispiel im User-Mode, mit 
dem Return- Bofehl aus der Exception-Bearbeitung zuriickspringen. Bei Reset, 
Bus-Fehler und Adress-Fehler wird die aktuelle Instruktion aber nicht zu Ende 
gefiihrt, und es wird je nach Prozessor- und Exception- Typ ein unterschiedliches 
Stack frame angelegt. Speziell beim Bus-Fehler werden sehr weitgehende dia- 
gnostische Informationen geliefert; der Grund hierfur ist, dass bei Systemen mit 
virtuellem Memory die gesamte Speicherumschaltung im Bus-Fehler Exception- 
Unterprogramm verwaltet wird. Wenn man also tatsachlich auch beim Bus- 
Fehler den iiblichen VVeg des Riicksprungs aus der Exception-Bearbeitung ge- 
hen wollte, miisste man eine detaillierte Prozessor-Erkennung und eigenstandige 
Stack frame- Verwaltung vornehmen. Tabelle 2 zeigt die jeweilige Grosse des 
Stack frame bei Bus- Error in Abhangigkeit vom Prozessor- Typ. 
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Erkennen von Exceptions 



Prozcssor-Typ 



St a r k fra mc- 1 yp C i ross ( 



68000 14 Byte 

68008 14 By to 

68010 Format, $8 40 Byte 

68012 Format $8 40 Byte* 

68020 (Instruktions-Zugriff) Format $A 30 Byte 

68020 (Instruktions-Wrarheitung) Format $B 90 Byte 

Abbildung 4: Typ unci (J rosso des Stack frame beim Bus-Frror in Abhangigkeit 
voni Prozcssor-Typ 

Wegen dieses rolativ komplexen Sachverhalts wircl normalerweise davon abgera- 
ten, oigene Exception- Programme im System- Mode zu installioren; in dor oin- 
schlagigen Literatur findet sich ontspreohend dor Hinweis, dass Bus- unci Adress- 
Febler schwere System-Fehler anzeigen und dass es unwahrselieinlieh ist , jcMiials 
wieder zur normalen Programm-Ausfuhrung zuniekkehren zu konnon. 

Da es im vorliegenden Beispiek PruTnng dor Kxislenz einor pliysikalisehen Ad ros- 
so, aber zwingend erforderlich war, nach Auftroton eines Bus- Keillors wieder in 
don Treiber zuriickzus|)ringen, ohne dass der Bonutzer otwas von dor Kxception- 
Bearbeitnng erfahrt, wurde folgonde Losung verwendet: Vor dem kritisehen Pro- 
gram niscliritt wircl die Programm-Adresso, an der die Ausfiihrung nach der Fx- 
coption fortsetzen soil, sowie dor aktneile Stand des System Stack Pointers go- 
speichert. Im eigenen Exception- Unterprogramm wird dann nur ein Folder- Flag 
gesotzt, der System Stack Pointer zuruekgesetzt und nicht mit oinem Rotum- 
Befehl sondern einfaeh mit einem Branch-Bofelil auf die 1 Riicksprung-Adresse 
verzweigt. Auf diese Weise umgeht man samtliehe Probleme moglicher Prozessor- 
Inkompatibilitaten. 



Beispiel-Programm 



NoIRQ equ '/.0000011100000000 
StdExcpt ds.l 1 

SysStack ds.l 1 
SysSR ds.w 1 
Err 102 ds.b 1 

EXEntry move.b #0,Errl02(a2) 
move.w sr,SysSR(a2) 



Interrupt mask 
Standard bus error 

exception handler 
System stack pointer 
Status register 
Error flag 

Reset bus error flag 
Save status 



Beispiel-Programm 
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ori.w #NoIRQ,sr 
move . 1 #0,a3 
move.l D_MPUTyp(a6),d2 
cmp.l #68010, d2 
bcs.s EX000 
movec vbr,a3 
EX000 lea.l T_BusErr(a3) ,a3 

move.l (a3) ,StdExcpt(a2) 
lea.l Excptl02(pc) ,a4 
move. 1 a4, (a3) 
move.l a7,SysStack(a2) 

EXErrl02 move.l StdExcpt (a2) , (a3) 



move.w SysSR(a2),sr 
tst.b Errl02(a2) 
bne . s EXError 
moveq #0,dl 
rts 



EXExit 
EXError 



move.w #E$Param,dl 
ori.b #Carry,ccr 
bra.s EXExit 
Excptl02 move.b #1 ,Errl02(a2) 

move.l SysStack(a2) ,a7 
bra.s EXErrl02 



Disable all interrupts 
Default vector base 

Any MPU less than 68010? 
Yes, fixed vector base 
No, get vector base 
Get Standard bus error 

exception handler 
Save it 

Replace it by our own one 
Save system stack pointer 
Do any critical command 
Restore standard bus error 

exception handler 
Restore old IRQs 
Was bus error? 
Yes 
No error 

Provide specific treatment 
Parameter (or whatever) 
error 

Set bus error flag 
Restore SSP 
Resume execution 



Oarsten Emde hat die Entwicklung von OS-9 von Anfang an rniterlebt and ist 
irntner noch fasziniert davon. Seint Berufstdtigkeit umfassi Entwicklung von 
OS-9 System and Anwendtr Software sowie System-Integration von VMEbus- 
Rechnern. Er ist pnvat crrtichbar unter der Tel. Nr. +/ f 1 1 720 $\ 47 ode r per 
electronic mail an cmdtflwopr.opcn.ch. 

Wolfgang Ocker ist Inhaber der Firma reccoware systems. Er hat vor einigen 
Jahren OS-9 auf Atari ST Computer portiert mid widmet sich seither MOR, 
der grafischen Benutzeroberfldche , die er fur OS-9 verfugbar gemacht und stark 
erweitert hat. Er ist geschdftlich crrcichbar in Unter wittelsbach +49 8251 51 
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A Software Management System 



Malindi Lamb 

It is generally accepted that a piece of software or indeed any computer pro- 
ject undergoes various phases during its life time, generally referred to as the 

life-cycle. 

A typical life-cycle might he: 



Requirements/Specification 



Design 



Implementation 



'Festing 



Kach of these phases will involve the generation of documents, design diagrams, 
source code or other data. Most, if not all, of this information is likely to he held 
on computer. Furthermore, all of the information must he maintained as the 
software undergoes various revisions for hug fixes and upgrades to the facilities 
offered. 

Maintenance is accepted as being the most expensive element of a software pro- 
ject: the proportion of the cost of maintenance of a project is generally argued 
to be between 50% and 80%. Given the high cost of maintenance, tools which 
assist in the automation of maintenance procedures are extremely important 
and cost-effective. 



There are several related tasks which can be automated to assist in software 
management and maintenance: 



Version Control l]\ 

• Version ( Control 

• Configuration Management 

• Modification Request Management 

SMS is a software management system which addresses the problem of automa- 
ting maintenance procedures. It provides tools to assist, in all the above tasks. 

Kach organisation has its own existing procedures for Version Control, Confi- 
guration Management and Modification Request Management: any tools which 
are to assist in the automation of these tasks must, therefore be flexible enough 
to fit in with existing procedures. 

SMS achieves this flexibility by allowing users to set up their own default para- 
meters for all aspects of the system on a project-by-project, or even file-by-file 
basis. 

Version Control 

Throughout the life cycle of a software project, documents and source code 
undergo a number of revisions as the requirements change, or the software is 
developed and updated to incorporate new facilities or correct bugs. 

Version Control is the process of maintaining a history of these revisions. Given 
this revision history such vital questions as: 

• What changes were made ? 

• Who made the changes ? 

• When were the changes made ? 

• Why were the changes made ? 

can all be answered. 

A manual Version Control System can probably answer some of these questi- 
ons, but, the information may not be readily available. All too often the manual 
Version Control procedures are not enforced, since it is a time consuming and 
tedious process, so the information available may not be accurate or up-to-date. 
Furthermore, to maintain manually all revisions of a file or number of files in- 
volves keeping complete copies of the files, which is very expensive in storage 
space. 



IV2 A Software Management System 

An automated Version Control system should maintain a revision history of a 
file by storing only the changes between one revision and the next. This is ex- 
tremely efficient in terms of storage space, and also enables the Version Control 
system to show exactly what lines of code changed between one revision and 
another. 

An automated Version Control system should have the capability to maintain 
not only text files but also data or object files, such as diagram files, data-bases 
etc. Furthermore, special facilities need to be provided to allow wordprocessor 
documents to be maintained under the Version Control system. 

A fully featured Version Control system also needs to provide facilities for: 

• access control 

• separate lines of development and the merging of separate lines of deve- 
lopment into the main line of development 

• automatic revision identification with name, revision number, date etc. 

• flexible and powerful report generation 

SMS provides all of the above essential features, plus a number of further faci- 
lities. 



Configuration Management 

Configuration Management is the process of managing what makes up a confi- 
guration of a piece of software. 

This incorporates Version Control for the management, of the versions of the 
modules/programs making up a configuration ol a software package. 

A ( 1 on figuration of a software package could be regarded as a slice across the ver- 
sions of the modules making up the software. A particular configuration (CON- 
FIC) may consist of version 1.4 of module /, version 1.7 of module 2 and version 
1.2 of module:.'], as illustrated in the diagram below. 



Modification Request Management 
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In order to automata (Configuration Management , Version Control tools air re- 
quired, and those must allow a configuration to be described as a slice across the 
versions; it should also provide a tool to allow a configuration to be* automatically 
ret rievod and built. 

SMS provides methods of managing configurations by the use of symbolic na- 
mes to describe a configuration and a, build utility to generate configurations, 
maintain them up to date and ensure data integrity during development or 
maintenance tasks. 



Modification Request Management 



Modification (or Change) Requests are bug reports or upgrade requests. Mana- 
ging these is of great importance in the maintenance process: managers need to 
know what requests arc* outstanding, what stage they have reached etc. 

Furthermore, there is a direct, relationship between the versions of software and 
the Modification Requests: new versions are in response* to a Modification Re- 
quest. 

Most organisations have* manual bug reporting and upgrade request procedures, 
which, as with manual version control systems, may not be accurately main- 
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tained or kept up-to-date. If they are, then automating the process would save 
considerable time and probably provide facilities/information difficult to obtain 
with a manual system. 

Every organisation has a different Modification Request system, so an automated 
system should be flexible to allow it to fit in with existing procedures. 

SMS provides a Modification request system which is extremely flexible and fully 
integrated with the Version Control System. 

Modification Request management involves: 

• the assignment of Modification Requests to programmers and notifying 
them that they have been assigned the task of dealing with an MR 

• the movement of MRs through various statuses, for example: accepted --» 
fixing — » testing — > completed — ► released 

• the notification of appropriate personnel on status changes and the repor- 
ting of information about MRs 

SMS provides all these facilities while still maintaining flexibility and allowing 
precise statuses used, their names, notifications and so on to be determined by 
each organisation. 



Conclusion 

SMS provides a fully integrated Software Management environment, providing 
facilities for Version Control, Configuration Management and Modification Re- 
quest Management. 

It also provides a menu-driven front-end with full context-sensitive on-line help 
to allow the benefits of using the system to be achieved with a minimal learning 
curve. 

It is unique in providing a total integrated solution with all the facilities required. 



Mrs Malindi Lamb is sales manager at Intasoft Ltd., England. She can be reached 
during office hours at (0392) S J 7670. 
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Werbung 



OS-9 International stollt ITir Sio als Firma. die in den Heroichen OS-9. VMKbus, 
Iiulnst ric^l lo Inlornialik und Automat isat ion tatig ist . ein ausserst interessantes 
Werbemit tel dar. 

Mil einem Inserat in OS-9 International erreichen Sic <lir<*kt Ihr gewiinscbtes Ziel- 
puhlikum. Im (iegonsatz zu andoron Publikat ionen wendet sicli OS-9 Internatio- 
nal ausschlirsslirh an OS-9 Anwender. Kino konzent rierte \\ erbewirksamkeit ist 
garant iert . 

Yorlangen Sic* uiis(mv Insert ionsbedingen und die zurzeit giiltige Anzeigenpreis- 

liste. 



Abonnemente 



Die erste NumiiuT von OS-9 International haben Sio als Probonummer gratis 
erhalten. 

OS-9 International konnen Sic 1 nur im Abonnement oder einzeln beim Heraus- 
geber bezielion. Die Finzelnummer kostot CIIF/DM 8.00, ein Abonnement fur 
seehs Ansgabon kostot CHF/DM F r >.00. Fniversitatem Ilochschulon und Insti- 
tute 1 konnen ein Sammelabonnement bestellem Fin* don Preis von CHF/DM 
100.00 erhalten Sio die naehsten seehs Ansgabon in jevveils zehu Kxemplaron. 
Sehieken Sio noeh houte Hue Karto mit Ihrer Adresse an: 

OS-9 International 

u Abonnemente" 
Hagentalerstrasse \2 
CH-lO/Vi IW1 

Vergessen Sic 1 nieht zu vortnorkon, ob Sir Hn Abonnement fur seehs odor zwolf 
Ansgabon wunsrhen. Zusammen mit dor naehsten Ausgabe orhalton Sic 1 die 
Abonnementsreehnung. 

Dor Finzelverkaufspreis von OS-9 International betragt im Moment, CHF/DM 
8.00, 
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Artikel gesucht 

Fiir die nachsten Ausgabon suction wir nocli Artikeh Publiziert werden Artikeh 
die OS-!) in irgondeiner Form zum Iuha.lt haben. Sowohl Programme als audi 
Morichte iibrr deren Futstehem speziolle Troiber oder Frfahrungon mi t einetn he- 
stimmten System siiul willkommen. Scliiekon Sic eino kurze Zusamnientassiing 
Hirer Arbeit oder don kompletten Artikel zusammen mil einigen Angaben zu 
Hirer Person an unsere Adresse. 

Artikel konnen Sie als ASCII-Text in einem dor lolgenden Disket tenlormate 
zusendon: Alio 0S-<) Formate, MS-DOS, Atari ST, Apple Macintosh. Andore 
Formate naeh Al)spraehe. 



Impressum 

OS-9 International. Magazin fur OS f) Anwender. 

herausgegebeu von Marc Maimer 

Audago: 1000 Kx. 

Redaktiou und ( iestaltung: Marc Maimer und Oarsten Fmde 

Adrosse: OS-9 International. Marc Maimer. Ilagent alerst rasse 12. CIF10 r ) r > Masol 

Fleet ronic Mail: os9-info ( ' urz.unibas.ch 

Nameiitlieh gekennzeiehnet e Meitrage miisstMi nicht unbodingt der Meinung dor 
Hedaktion entsprechen. 



Vorschau 



In der nachsten Ausgabe von OS-9 International werden vvir voraussichtlich fol- 
gonde Thomon behandeln: 

• EFFO Forum 21. Inhalt des FFFO Forum 21 

• Grafische Benutzeroberflachen fiir OS-9: MGR. Finer dor Punkte, 
warum OS-9 Millie hat, sich durchzusetzen, sind die mangelnden (Jra- 
fikfahigkeiten. Kommandozeilen-Interfaces sind etvvas fiir Fxperten odor 
regelmassige OS-9 Benutzer, gelegentliche OS-9 Benutzer vviinschen aber 
cine etvvas intuitivere Bedienung des Systems. 

• Terminalauswahl beim Log-In. Wer oft an verschiedenen Ports rin- 
loggt, kennt das Problem: Die Terminalemulat ion ist in der Kegel falsrh 
eingcstellt. Das liter vorgestellte Verfahren kann dieses Problem losen. 

• Wer ist CoVe?. Der ( 1 oni|)uter Verein Frankfurt e.Y. stellt sich vor. 

• Ein europaisches Netzwerk fiir OS-9 Benutzer. Fs win! ein Yor- 
schlag gemacht, wie ein gesamteuropaisches Netzwerk fur den elektroni- 
schen Post-Yerkehr unci den Austausch von Informal ionen und Program- 
men aussehen konnte und wie sieh der einzelne Benutzer ansrhliessen kann. 
Dieses Netzwerk lauft in der Schweiz bereits erfolgreich. 

• Interprozess-Kommunikation. Unter OS-9 ist es relativ ein fax ii, zvvei 
oder mehrere Prozesse niiteinander kommunizieren zu lassen. Wie's ge- 
inacht vvird st edit in der nachsten Ausga.be. 

• Portierung von UNIX Software auf OS-9. VVelehe Problenie stel- 
len sich, wenn man UNIX Software auf OS-9 portieren mochte? Sind der 
Portierungs-Lust. (Irenzon gesetzt? Kinige Frfahrungen desjenigen Mamies, 
der den (!NU ( 1 Compiler fiir OS-9 portiert hat und ihti der Allgemeinheit 
zu Verfiigung stellt. 

• Pseudo TTYs. Was PTYs sind und wie sie benutzt werden. 

An dieser Stelle mochten vvir nochinals darauf hinweisen, dass OS-9 Internatio- 
nal nur ini Abonnement erhaltlich ist. Schirken Sie mis noch heute eine Karte 
mil Hirer Adresse wenn Sie OS-9 International weiferhin erhalten mochten (siehe 
Seite "In eigener Sache" fiir Details). 



